2 // PurpleMySpaceService.m
5 // Created by Evan Schoenberg on 9/11/07.
8 #import "PurpleMySpaceService.h"
9 #import "PurpleMySpaceAccount.h"
10 #import "PurpleMySpaceAccountViewController.h"
11 #import <Adium/AIStatusControllerProtocol.h>
12 #import <AIUtilities/AIImageAdditions.h>
14 @implementation PurpleMySpaceService
17 - (Class)accountClass{
18 return [PurpleMySpaceAccount class];
21 - (AIAccountViewController *)accountViewController{
22 return [PurpleMySpaceAccountViewController accountViewController];
25 - (DCJoinChatViewController *)joinChatView{
30 - (NSString *)serviceCodeUniqueID{
31 return @"libpurple-MySpace";
33 - (NSString *)serviceID{
36 - (NSString *)serviceClass{
39 - (NSString *)shortDescription{
42 - (NSString *)longDescription{
45 - (NSCharacterSet *)allowedCharacters{
46 return [NSCharacterSet characterSetWithCharactersInString:@"+abcdefghijklmnopqrstuvwxyz0123456789@._-"];
48 - (NSCharacterSet *)ignoredCharacters{
49 return [NSCharacterSet characterSetWithCharactersInString:@""];
54 - (BOOL)caseSensitive{
57 - (AIServiceImportance)serviceImportance{
58 return AIServiceSecondary;
60 - (NSString *)userNameLabel{
61 return AILocalizedString(@"Email", "Used as a label for a username specified by email address");
63 - (NSString *)contactUserNameLabel{
64 return AILocalizedString(@"MySpace ID", "Label for the username for a MySpace contact");
66 - (void)registerStatuses{
67 [[adium statusController] registerStatus:STATUS_NAME_AVAILABLE
68 withDescription:[[adium statusController] localizedDescriptionForCoreStatusName:STATUS_NAME_AVAILABLE]
69 ofType:AIAvailableStatusType
72 [[adium statusController] registerStatus:STATUS_NAME_AWAY
73 withDescription:[[adium statusController] localizedDescriptionForCoreStatusName:STATUS_NAME_AWAY]
74 ofType:AIAwayStatusType
77 [[adium statusController] registerStatus:STATUS_NAME_INVISIBLE
78 withDescription:[[adium statusController] localizedDescriptionForCoreStatusName:STATUS_NAME_INVISIBLE]
79 ofType:AIInvisibleStatusType
86 * Service Icon packs should always include images for all the built-in Adium services. This method allows external
87 * service plugins to specify an image which will be used when the service icon pack does not specify one. It will
88 * also be useful if new services are added to Adium itself after a significant number of Service Icon packs exist
89 * which do not yet have an image for this service. If the active Service Icon pack provides an image for this service,
90 * this method will not be called.
92 * The service should _not_ cache this icon internally; multiple calls should return unique NSImage objects.
94 * @param iconType The AIServiceIconType of the icon to return. This specifies the desired size of the icon.
95 * @return NSImage to use for this service by default
97 - (NSImage *)defaultServiceIconOfType:(AIServiceIconType)iconType
99 //If we're going to do it this way, we've got to return the small icon for both AIServiceIconSmall and the AIServiceIconList icons.
100 return [NSImage imageNamed:((iconType == AIServiceIconSmall || iconType == AIServiceIconList) ? @"MySpace-small" : @"MySpace-large")
101 forClass:[self class] loadLazily:YES];